<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>layui</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <link rel="stylesheet" href="../../../lib/layui-v2.5.5/css/layui.css" media="all">
    <link rel="stylesheet" href="../../../css/public.css" media="all">
</head>
<body>
<div class="layuimini-container">
    <div class="layuimini-main">
		<!-- 搜索开始 -->
        <fieldset class="layui-elem-field layuimini-search">
            <legend>搜索信息</legend>
            <div style="margin: 10px 10px 10px 10px">
                <form class="layui-form layui-form-pane" action="" id="searchForm">
                    <div class="layui-form-item">
						<div class="layui-inline">
						    <label class="layui-form-label">所属部门</label>
						    <div class="layui-input-inline">
								<input type="hidden" name="deptid" id="p_deptid" />
						        <input type="text" name="p_deptName" id="p_deptName" autocomplete="off" class="layui-input">
								
						    </div>
						<a class="layui-btn layui-btn-warm" id="doSelectDept"><label class="layui-icon layui-icon-male"></label>选择 </a>
						</div>
                        <div class="layui-inline">
                            <label class="layui-form-label">用户名称</label>
                            <div class="layui-input-inline">
                                <input type="text" name="name" autocomplete="off" class="layui-input">
                            </div>
                        </div>
                        <div class="layui-inline">
                            <label class="layui-form-label">用户备注</label>
                            <div class="layui-input-inline">
                                <input type="text" name="remark" autocomplete="off" class="layui-input">
                            </div>
                        </div>
                        <div class="layui-form-item">
                            <div class="layui-block" style="text-align: center;">
                            	<a class="layui-btn " lay-submit=""  lay-filter="data-search-btn"><label class="layui-icon layui-icon-search"></label>搜索</a>
                            	<a class="layui-btn layui-btn-warm" onclick="javascript:$('#searchForm')[0].reset();$('#p_deptid').val('')" lay-filter="data-search-btn"><label class="layui-icon layui-icon-refresh"></label>重置</a>
                            </div>
                        </div>
                   
                       
                    </div>
                </form>
            </div>
        </fieldset>
		<!-- 搜索开始 -->

	<!--表格开始-->
        <table class="layui-hide" id="userTable" lay-filter="userTable"></table>
        <script type="text/html" id="userToolBar">
			 <a class="layui-btn layui-btn-sm " lay-event="addUser">添加</a>
        </script>
		<script type="text/html" id="userTableBar">
			 <a class="layui-btn layui-btn-xs layui-btn-warm   data-count-delete" lay-event="update">修改</a>
		     <a class="layui-btn layui-btn-xs layui-btn-danger data-count-delete" lay-event="delete">删除</a>
			 <a class="layui-btn layui-btn-xs layui-btn-warm   data-count-delete" lay-event="selectRole">分配角色</a>
			   <a class="layui-btn layui-btn-xs layui-btn-danger data-count-delete" lay-event="resetPwd">重置密码</a>
		</script>
		<!--表格结束-->
		
		<script type="text/html" id="availableTpl">
		  <!-- 这里的 checked 的状态只是演示 -->
		  <input type="checkbox" name="available" value="{{d.id}}" lay-skin="switch" lay-text="可用|不可用" lay-filter="availableSwitch" {{ d.available == 1 ? 'checked' : '' }}>
		</script>
		
		<!-- 增加修改弹出层开始 -->
     <div id="addOrUpdateDiv" style="display: none; padding: 0.375rem;" >
     	<form method="post" class="layui-form layui-form-pane" lay-filter="dataFrm" id="dataFrm">
     		
     		  <div class="layui-form-item"id="div_pid">
     		    <label class="layui-form-label">所属部门</label>
     		    <div class="layui-input-inline" >
     			  <input type="hidden" name="id" />
     			  <input name="deptid" hidden="hidden" id="deptid" />
     		      <input type="text"  id="deptid_name" readonly="readonly" autocomplete="off" placeholder="请选择所属部门" class="layui-input">
     		    </div>
     			<div class="layui-input-block">
     				<a class="layui-btn layui-btn-warm" id="doDataFromSelectDept"><label class="layui-icon layui-icon-male"></label>选择 </a>
     			</div>
     		  </div>
			  
			  
			  <div class="layui-form-item">
				  <div class="layui-inline ">
				    <label class="layui-form-label">用户姓名</label>
				    <div class="layui-input-inline">
				      <input type="text" name="name" id="name" lay-verify="required" autocomplete="off" placeholder="请输入用户姓名" class="layui-input">
				    </div>
				  </div>
				  
				  <div class="layui-inline ">
				    <label class="layui-form-label">登录名称</label>
				    <div class="layui-input-inline">
				      <input type="text" name="loginname" id="loginname" lay-verify="required" autocomplete="off" placeholder="请输入登录名称" class="layui-input">
				    </div>
				  </div>
			  </div>
     		  
     		  <div class="layui-form-item">
     		    <label class="layui-form-label">用户地址</label>
     		    <div class="layui-input-block">						
     		      <input type="text" name="address"  autocomplete="off" placeholder="请输入用户地址" class="layui-input">
     		    </div>
     		  </div>
     		  
     		<div class="layui-form-item">
     		  <label class="layui-form-label">用户备注</label>
     		  <div class="layui-input-block">
     		    <textarea name="remark"   placeholder="请输入用户备注" class="layui-textarea"></textarea>
     		  </div>
     		</div>
     		
     		<div class="layui-form-item">
     			<div class="layui-inline">
     				<label class="layui-form-label">入职时间</label>
     				<div class="layui-input-inline">
     					<input type="text" name="hiredate" id="hiredate" readonly="readonly" autocomplete="off" class="layui-input">
     				</div>
     			</div> 
     			<div class="layui-inline">
     				<label class="layui-form-label">排序码</label>
     				<div class="layui-input-inline">
     					<input type="text" name="ordernum" id="ordernum"  placeholder="请输入排序码" autocomplete="off" class="layui-input">
     				</div>
     			</div>
     	    </div>
			
			<div class="layui-form-item">
				<div class="layui-inline">
					<label class="layui-form-label">用户性别</label>
					<div class="layui-input-inline">
						<input type="radio" name="sex" value="1" title="男" checked="checked" class="layui-input">
						<input type="radio" name="sex" value="2" title="女"   class="layui-input">
					</div>
				</div> 
			</div>
     		
     		  <div class="layui-form-item">
     		    <div class="layui-input-block" style="text-align: center;">
     				<a class="layui-btn " lay-submit=""  lay-filter="doSubmit"><label class="layui-icon layui-icon-release"></label>提交</a>
     				<a class="layui-btn layui-btn-warm" onclick="javascript:$('#dataFrm')[0].reset()" lay-filter="data-search-btn"><label class="layui-icon layui-icon-refresh"></label>重置</a>
     		    </div>
     		  </div>
     		  
     	</form>
     </div>
		<!-- 增加修改弹出层结束 -->
		
		<!-- 打开用户角色的弹出层开始 -->
		<div id="selectRoleDiv"style="display: none;padding: 0.375rem;">
			 <table class="layui-hide" id="roleTable" lay-filter="roleTable"></table>
		</div>
			
		<!-- 打开菜单和权限的弹出层结束 -->
		
		
		
    </div>
</div>
<script src="../../../lib/jquery-3.4.1/jquery-3.4.1.min.js" charset="utf-8"></script>
<script src="../../../lib/layui-v2.5.5/layui.js" charset="utf-8"></script>
<script src="../../../js/lay-config.js?v=1.0.4" charset="utf-8"></script>
<script src="../../../lib/jq-module/jquery.particleground.min.js" charset="utf-8"></script>
<script src="../../../lib/common/jquery.cookie.min.js" charset="utf-8"></script>
<script src="../../../lib/common/common.js " charset="utf-8"></script>
<script src="../../../lib/common/selectLayer.js " charset="utf-8"></script>
<script src="../../../lib/common/Convert_Pinyin.js" charset="utf-8"></script>

<script>
    layui.use(['form', 'table','layer','laydate'], function () {
        var form = layui.form;
        var table = layui.table;
		var layer = layui.layer;
		var laydate = layui.laydate;
		
		laydate.render({
			elem:"#hiredate",
			type:"date"
		})
		

     var tableObj=  table.render({
            elem: '#userTable',
            url: api+'user/loadAllUser',
		    toolbar:"#userToolBar",
			height:'full-200',
            cols: [[
                {field: 'id', title: 'ID', align: "center",width:60},
                {field: 'name',title: '用户姓名', align: "center",width:80},
				{field: 'loginname',title: '登录名称', align: "center",width:100},
				{field: 'deptName',title: '所属部门', align: "center",width:80},
                {field: 'remark', title: '用户备注', align: "center",width:100},
				{field: 'hiredate', title: '入职时间', align: "center",width:120},
				{field: 'sex', title: '性别', align: "center",width:60,templet:function(d){
					return d.sex==1?"男":"女";
				}},
				{field: 'available', title: '是否可用', align: "center",width:100,templet:'#availableTpl'},
				 {field: 'ordernum',  title: '排序码', align: "center",width:60},
                {field: 'imgpath',  title: '用户头像', align: "center",width:100,templet:function(d){
					return "<img width:30 height:30 src='"+baseUrl+d.imgpath+"' />"
				}},
                {title: '操作',templet: '#userTableBar', fixed: "right", align: "center",width:300}
            ]],
            limits: [10, 15, 20, 25, 50, 100],
            limit: 15,
            page: true
        });
		
		//监听toolbar事件
		table.on('toolbar(userTable)', function(obj){
		  var checkStatus = table.checkStatus(obj.config.id); 
		  switch(obj.event){
		    case 'batchdelete':
				 //批量删除
				 batchDelete();
		    break;
				 case 'addUser':
				 openAddUser();
				 break;
		  };
		});
		
		
		
		//监听行事件
		table.on('tool(userTable)', function (obj) {
		    var data = obj.data;
		    if (obj.event === 'delete') {
		        layer.confirm('真的删除这个用户么', function (index) {
					$.post(
					api+"user/deleteUser",
					{id:data.id},
				function(res){
					 layer.msg(res.msg);
					 obj.del();
					 layer.close(index);
					})                 
		        });	
		    }else if(obj.event==="update"){
				openUpdateUser(data);
			}else if(obj.event==="resetPwd"){
				resetPwd(data);
			}else if(obj.event==="selectRole"){
				openSelectRole(data);
			}
		});
		
		
		
		//重置密码
		function resetPwd(data){
			layer.confirm('真的要重置密码吗', function (index) {
				$.post(
				api+"user/resetUserPwd",
				{id:data.id},
			function(res){
				 layer.msg(res.msg);
				 layer.close(index);
				})                 
			});	
		}
		
		
		
		//监听部门选择的事件
		$("#doSelectDept").click(function(){
			openDeptSelecter("",function(id,name){
				$("#p_deptid").val(id);
				$("#p_deptName").val(name);
			})
		})
		
		
		
		//监听部门选择的事件
		$("#doDataFromSelectDept").click(function(){
			var f_id=$("#deptid").val();
			openDeptSelecter(f_id,function(id,name){
				$("#deptid").val(id);
				$("#deptid_name").val(name);
			})
		})
		
		//打开弹出层
		var mainIndex;
		var url;
		function openAddUser(){
			mainIndex=layer.open({
				 type: 1,
				 title:'添加用户',
				 content:$("#addOrUpdateDiv"),
				 area:['800px','600px'],
				 success:function(index){
					 url=api+"user/addUser";
					 $("#dataFrm")[0].reset();
					 //查询最大排序码
					 $.get(api+'user/queryUserMaxOrderNum',function(res){
						 $("#ordernum").val(res.data)
					 })
				 }
			});
		}
		
		function openUpdateUser(data){
			// alert(JSON.stringify(data))
			mainIndex=layer.open({
				 type: 1,
				 title:'修改['+data.name+']用户',
				 content:$("#addOrUpdateDiv"),
				 area:['800px','600px'],
				 success:function(index){
					 url=api+"user/updateUser";
					 //装载数据表格 
					 form.val("dataFrm",data);
					 	$.get(api+"dept/getDeptById",{id:data.deptid},function(res){
							$("#deptid_name").val(res.data.title);
						});
				 }
			});
		}
		
		//查看用户
		function showUser(data){
			var title=data.title;
			var content=data.content;
			var userTime=data.createtime;
			var author=data.opername;
			var html = '<div style="padding:15px 20px; text-align:justify; line-height: 22px;border-bottom:1px solid #e2e2e2;background-color: #2f4056;color: #ffffff">\n' +
			    '<div style="text-align: center;margin-bottom: 20px;font-weight: bold;border-bottom:1px solid #718fb5;padding-bottom: 5px"><h4 class="text-danger">' + title + '</h4></div>\n' +
			    '<div style="font-size: 12px">' + content + '</div>\n' +
			    '</div>\n';
			parent.layer.open({
			    type: 1,
			    title: '系统用户'+'<span style="float: right;right: 1px;font-size: 12px;color: #b1b3b9;margin-top: 1px">'+'发布时间'+userTime+'&nbsp;&nbsp;&nbsp;发布人'+author+'</span>',
			    area: '800px;',
			    shade: 0.8,
			    btn: ['关闭'],
			    btnAlign: 'c',
			    moveType: 1,
			    content:html,
			 
			});

		}
		
		
		// 提交数据
		form.on("submit(doSubmit)",function(data){
		    var params=$("#dataFrm").serialize();
			$.post(url,params,function(res){
				layer.msg(res.msg);
				if(res.code==200){
					tableObj.reload();
				}
				//关闭弹出层
				layer.close(mainIndex);
			})
			
			return false;
		})




        // 监听搜索操作
        form.on('submit(data-search-btn)', function (data) {			
			var params=$("#searchForm").serialize();
			// alert(params)
            //执行搜索重载
            table.reload('userTable', {
                page: {
                    curr: 1
                },
				 url: api+'user/loadAllUser?'+params,     
            });

            return false;
        });

   
	 
	 
	 //监听是否可用事件
	 form.on('switch(availableSwitch)', function(obj){
	 		  $.post(api+"user/updateUser",{id:this.value,available:obj.elem.checked?1:0},function(res){
	 		  	layer.msg(res.msg);
	 		  	tableObj.reload();
	 		  });
	   });

    
	
		
		
		function batchDelete(){
			var checkStatus = table.checkStatus('userTable'); //idTest 即为基础参数 id 对应的值
			var data=checkStatus.data;
			var length=checkStatus.data.length;
			if(length==0){
						 layer.msg("请选择所要删除的行")
			}else{
						 layer.confirm('真的删除行么', function (index) {
							 var params="";
							 $.each(data,function(index,item){
								 if(index=0){
								 	 params+="ids="+item.id;			 
								 }else{
									 params+="&ids="+item.id; 
								 }
							 });
							 $.post(
							 api+"user/batchDeleteUser",
							 params,
							 function(res){
								 layer.msg(res.msg);
								 tableObj.reload();
								  layer.close(index);
							 })						    
						 });
			}
		}
		
		
		//打开选择角色弹出层
		function openSelectRole(data_table){
			var table_RoleIns;
			mainIndex=layer.open({
				 type: 1,
				 title:'分配['+data_table.name+']用户角色的菜单',
				 content:$("#selectRoleDiv"),
				 area:['800px','600px'],
				 btn:['<span class="layui-icon layui-icon-ok">确认分配</span>'],
				 btnAlign:'c',
				 yes:function(){ //监听按钮事件
				    var checkStatus=table.checkStatus('roleTable'); //
					var m= checkStatus.data;  //获取选中行的数据
					var uid=data_table.id;
					var params="uid="+uid;
					
					$.each(m,function(x,item){
						params+="&rids="+item.id;
					});
					// alert(params);
					$.post(api+"user/saveUserRole",params,function(res){
						layer.msg(res.msg);
						// table_RoleIns.close();
						layer.close(mainIndex);
					})
				 },
				 success:function(index){
					  table_RoleIns=  table.render({
					        elem: '#roleTable',
					        url: api+'role/loadAllAvailableRoleNoPage?userId='+data_table.id,
					 		    toolbar:"#roleToolBar",
								cellMintWidth:true,
					        cols: [[
					            {type: "checkbox", fixed: "left"},
					            {field: 'id', title: 'ID', align: "center"},
					            {field: 'name',title: '角色标题', align: "center"},
					            {field: 'remark', title: '角色备注', align: "center"},
					 				{field: 'available', title: '是否可用', align: "center",width:100,templet:'#availableTpl'},
					       
					        ]],
					        page: false
					    });
					 		
					 
				 }
			});
		}


		//用户名转登录名小写
		$("#name").on("blur",function(){
			var name=$("#name").val();
			var fullName=pinyin.getFullChars(name).toLowerCase();
			$("#loginname").val(fullName);
			
		})

		
    });
</script>
<script>

</script>

</body>
</html>